flask框架之 | 您所在的位置:网站首页 › flask 会话 › flask框架之 |
安装:pip3 install flask-login
介绍:
LoginManager是一个类,有多个方法和属性;此类初始化的对象用于保存用于登录的设置。实例:class:LoginManager * *不绑定到特定应用程序,因此可以在代码的主体中创建一个,然后将其绑定到应用程序app中 工厂函数。 初始化: login-manager=LoginManager() 配置: login_manager.init_app(app) 方法:user_loader() 回调函数: 这将设置从会话重新加载用户的回调。 您设置的函数应该使用用户ID(“unicode”)并返回用户对象,如果用户不存在则返回“None”。 reload_user(): 1、首先获取user id,如果获取不到有效的id,就将user设为anonymous user 2、获取到id后,再通过@login_manager.user_loader装饰的函数获取到user对象,如果没有获取到有效的user对象,就认为是anonymous user 3、最后将user保存于request context中(无论是正常的用户还是anonymous用户) 属性:login_manager.login_view :验证失败后跳转的页面 login_manager.login_message:用户重定向到登录页面闪现的消息; login_manager.refresh_view: 用户重新进行身份验证需要重定向的视图 login_manager.need_refresh_view::用户重定向到“需要刷新”页面时闪出的消息。 login_manager.session-protection:使用会话保护的模式。这可以是'basic'(默认)或'strong',或None禁用 功能函数:@login_required:这是一个装饰器用来验证登录的用户是否正常。 """权限访问""" def login_required(view): # 限制必须登录才能访问的页面装饰器 @functools.wraps(view) def wrapped_view(**kwargs): if g.user is None: #给登录添加一个上次访问的url redirect_to=f"{url_for('auth.login')}?redirect_to={request.path}" return redirect(redirect_to) if g.user.has_prem: pass else: return '无权查看' return view(**kwargs) return wrapped_viewLogin_user() 用户登录操作,用户在通过自定义的login视图函数,通过验证并登录成功后,login_user可以记录或者保存成功登录的用户。 logout_user() 登出功能类似,除了基本的操作外,还需要把flask-login中的登出进行操作。 |
CopyRight 2018-2019 实验室设备网 版权所有 |